1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
| class Solution { private: int res = 0;
public: int diameterOfBinaryTree(TreeNode *root) { height(root); return res; } int height(TreeNode *node) { if (node == nullptr) { return 0; } int lHeight = height(node->left); int rHeight = height(node->right); res = max(res, lHeight + rHeight); return max(lHeight, rHeight) + 1; } };
|